package 春招冲刺百题计划;

/**
 * Created with IntelliJ IEDA.
 * Description:
 * User:86186
 * Date:2024-04-28
 * Time:21:29
 */

/**
 * 春招冲刺百题计划:125. 验证回文串
 * 已解答
 * 简单
 * 相关标签
 * 相关企业
 * 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后，短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
 * 字母和数字都属于字母数字字符。
 * 给你一个字符串 s，如果它是 回文串 ，返回 true ；否则，返回 false 。
 * 示例 1：
 * 输入: s = "A man, a plan, a canal: Panama"
 * 输出：true
 * 解释："amanaplanacanalpanama" 是回文串。
 */
public class isPalindrome {
    public static boolean isPalindrome(String s) {
        if(s == null || s.length() == 0) return true;
        int left = 0;
        int right = s.length() - 1;

        while(left < right){
            char l = Character.toLowerCase(s.charAt(left));
            char r = Character.toLowerCase(s.charAt(right));

            if(!Character.isLetterOrDigit(l)){
                left++;
            } else if(!Character.isLetterOrDigit(r)){
                right--;
            } else {
                if(l != r){
                    return false;
                }
                left++;
                right--;
            }
        }

        return true;
    }
}
